import Vue from 'vue'
import App from './App.vue'
import router from './router'
import axios from 'axios';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css'; // 默认主题
// import '../static/css/theme-green/index.css';       // 浅绿色主题
import './assets/css/icon.css';
import './components/common/directives';
import "babel-polyfill";




import * as socketApi from './components/common/webStock'
Vue.prototype.socketApi = socketApi;

import echarts from 'echarts'
Vue.prototype.$echarts = echarts;

import glo_loading from './loading/index' //loading组件的简单封装
import {routerLoading} from './config/index' //全局的页面跳转loading是否启用
import {modelGolbParam} from './config/index' //全局的页面跳转loading是否启用

Vue.prototype.$modelGolbParam = modelGolbParam

Vue.config.productionTip = false
Vue.use(ElementUI, {
    size: 'small'
});
Vue.prototype.$axios = axios;

// 将自动注册所有组件为全局组件  dataV
import dataV from '@jiaminghi/data-view'
Vue.use(dataV)

//rsa加密
import JSEncrypt from 'jsencrypt';
Vue.prototype.$jsEncrypt = JSEncrypt

import bus from './components/common/bus'
//使用钩子函数对路由进行权限跳转
router.beforeEach((to, from, next) => {
    console.log('routerLoading::'+routerLoading)
    routerLoading ? glo_loading.loadingShow() : '' //如果全局启用页面跳转则加载loading
    bus.$emit('pathChanage',to.path); //全局监听路由
    const role = localStorage.getItem('ms_username');
    if (!role && to.path !== '/login') {
        next('/login');
    } else if (to.meta.permission) {
        // 如果是管理员权限则可进入，这里只是简单的模拟管理员权限而已
        role === 'admin' ? next() : next('/403');
    } else {
        // 简单的判断IE10及以下不进入富文本编辑器，该组件不兼容
        if (navigator.userAgent.indexOf('MSIE') > -1 && to.path === '/editor') {
            Vue.prototype.$alert('vue-quill-editor组件不兼容IE10及以下浏览器，请使用更高版本的浏览器查看', '浏览器不兼容通知', {
                confirmButtonText: '确定'
            });
        } else {
            next();
        }
    }
    routerLoading ? glo_loading.loadingHide() : ''//关闭loading层
})


let vue = new Vue({
    router,
    render: h => h(App)
}).$mount('#app')
export default vue